/* add_lh */
.lh ul{list-style: none;}
.lh ul li a:hover{color: var(--hover);}
.lh iframe{display: block; width: 100%; height: 500px;}
/* gioithieu */
.gth-img{height: calc(100% + 3rem);}
.gth-wrap{background-color: rgb(255 255 255 / 90%); box-shadow: 0 0 30px rgb(0 0 0 / 25%);}
.gt-title {
    margin-bottom: 2rem;
    font-family: var(--fnt);
    font-weight: 700;
    text-align: center;
    line-height: 0;
}

.gt-title * {
    display: block;
    line-height: 1.5;
    color: var(--main)!important;
}

.gt-title:after {
    content: '';
    display: inline-block;
    width: 60px;
    height: 2px;
    margin-top: 0.5rem;
    background-color: var(--hover);
    vertical-align: top;
}
.intro-actions .intro-profile-btn{
    gap:8px;
    background:linear-gradient(135deg,#fff8df,#fff)!important;
    color:var(--main)!important;
    border:1px solid rgba(218,37,28,.18);
    box-shadow:0 10px 24px rgb(218 37 28 / 10%);
}
.intro-actions .intro-profile-btn:hover{
    background:var(--hover)!important;
    color:#111!important;
    transform:translateY(-2px);
}

/* header_banner */
.banner{height: 350px; background: no-repeat center / cover; color: #fff;}
.banner:before{content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-color: rgb(0 0 0 / 50%);}
.breadcrumb{background-color: var(--main);}
.breadcrumb ul li{list-style: none; display: inline;}
.breadcrumb ul li+li:before{content: '/';}
.breadcrumb ul li a{color: var(--wite);}
/* header_menu */
header #menu{display: none;}
.menu{position: relative; z-index: 11;}
.menu ul{list-style: none;}
.menu ul li{position: relative;}
.menu ul li.display{display: none;}
.menu ul li a{display: block; font-size: 16px; font-weight: 700; line-height: 50px; color: var(--prev);}
.menu ul li a i{margin-left: 0.25rem; font-size: 12px; color: var(--prev); }
.menu ul li ul{position: absolute; top: 100%; min-width: 150px; opacity: 0; pointer-events: none; transition: all 0.5s ease 0s;}
.menu ul li ul li a{padding: 0 1rem; background-color: var(--white); text-wrap: nowrap; line-height: 36px;}
.menu ul li ul li a:hover{background-color: var(--main); color: var(--white);}
.menu > ul{display: flex; justify-content: center;}
.menu > ul > li{flex: 0 0 auto;}
.menu > ul > li+li{margin-left: 2rem;}
.menu > ul > li > a{text-transform: uppercase;}
.menu > ul > li:hover > a{color: var(--main);}
.menu > ul > li.active > a{color: var(--main);}
.menu > ul > li > ul:before{content: ''; position: absolute; bottom: 0; left: 0; width: 100%; height: 100%; box-shadow: 0 0 15px rgb(0 0 0 / 15%);}
.menu > ul > li:hover > ul{top: 100%; opacity: 1; pointer-events: auto;}
.mm-listitem__text i{display: none;}
/*menu c?p 2 bn ph?i*/
.menu ul li ul li ul{top: 0; left: calc(100% + 1rem);}
.menu ul li ul li:hover ul{left: 100%; opacity: 1; pointer-events: auto;}
/* header_slide */
.slide img{width: 100%; height: 100%; object-fit: cover;}
.slide .owl-nav button{position: absolute; top: 0; bottom: 0; width: 50px; height: 50px; margin: auto; background-color: rgb(255 255 255 / 25%); border-radius: 50%;}
.slide .owl-nav button.owl-prev{left: 30px;}
.slide .owl-nav button.owl-next{right: 30px;}
.slide .owl-nav button:hover{background-color: var(--wite);}
.slide .owl-nav button i{display: block; font-size: 24px; color: var(--main); transition: all 0.5s ease 0s;}
@media all and (max-width: 576px){
    .slide .owl-nav{display: none;}
}
/* home_dichvu */
.dichvu{
    margin-bottom:34px;
    padding:72px 0 62px;
    font-family:inherit;
    background:
        radial-gradient(circle at 12% 10%, rgba(218,37,28,.08), transparent 30%),
        radial-gradient(circle at 88% 12%, rgba(254,203,25,.20), transparent 25%),
        linear-gradient(180deg,#fff 0%,#f7f8fa 100%);
}
.dichvu:before{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(135deg,rgba(218,37,28,.04),transparent 44%,rgba(0,174,239,.05));
    pointer-events:none;
}
.dichvu:after{
    content:"";
    position:absolute;
    right:-120px;
    bottom:-160px;
    width:420px;
    height:420px;
    border:1px solid rgba(218,37,28,.12);
    border-radius:50%;
    pointer-events:none;
}
.dichvu .container{z-index:2;}
.dichvu-head{
    display:grid;
    grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);
    gap:28px;
    align-items:end;
    margin-bottom:34px;
}
.dichvu-kicker{
    display:inline-flex;
    align-items:center;
    gap:10px;
    color:var(--main);
    font-size:.92rem;
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:.4px;
}
.dichvu-kicker:before{
    content:"";
    width:34px;
    height:3px;
    background:var(--main);
}
.dichvu-head h2{
    margin:10px 0 0;
    color:#1f2933;
    font-size:1.95rem;
    font-weight:800;
    line-height:1.22;
}
.dichvu-head p{
    max-width:760px;
    margin:0 0 0 auto;
    color:#444;
    font-size:1rem;
    line-height:1.8;
    text-align:justify;
}
.dichvu-card{
    display:flex;
    flex-direction:column;
    overflow:hidden;
    background:#fff;
    border-radius:8px;
    border:1px solid #ededed;
    box-shadow:0 14px 34px rgb(0 0 0 / 9%);
    transition:transform .32s ease,box-shadow .32s ease;
}
.dichvu-card:hover{
    transform:translateY(-6px);
    box-shadow:0 22px 48px rgb(218 37 28 / 14%);
}
.dichvu-img{
    position:relative;
    display:block;
    overflow:hidden;
    background:#e9ecef;
}
.dichvu-img:before{
    content:"";
    position:absolute;
    inset:0;
    z-index:1;
    background:linear-gradient(180deg,transparent 45%,rgba(0,0,0,.28));
    opacity:.8;
    transition:opacity .3s ease;
}
.dichvu-img img{
    display:block;
    width:100%;
    aspect-ratio:4/3;
    object-fit:cover;
    transition:transform .45s ease;
}
.dichvu-card:hover .dichvu-img img{transform:scale(1.07);}
.dichvu-info{
    position:relative;
    flex:1;
    padding:24px 18px 18px;
}
.dichvu-icon{
    position:absolute;
    top:-26px;
    right:16px;
    display:flex;
    align-items:center;
    justify-content:center;
    width:58px;
    height:58px;
    background:#fff;
    color:#1f2933;
    border:4px solid #fff;
    border-radius:8px;
    font-size:1.2rem;
    box-shadow:0 10px 22px rgb(218 37 28 / 16%);
}
.dichvu-icon img{
    width:44px;
    height:38px;
    object-fit:contain;
}
.dichvu-info h3{
    margin:0 0 10px;
    min-height:50px;
    font-size:1rem;
    font-weight:700;
    line-height:1.45;
}
.dichvu-info h3 a{
    color:#1f2933;
    display:-webkit-box;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;
    overflow:hidden;
}
.dichvu-info h3 a:hover{color:var(--main);}
.dichvu-info p{
    margin:0 0 16px;
    min-height:58px;
    color:#555;
    font-size:.92rem;
    line-height:1.6;
}
.dichvu-more{
    display:inline-flex;
    align-items:center;
    gap:8px;
    color:var(--main);
    font-size:.9rem;
    font-weight:700;
}
.dichvu-more:hover{color:#111;}
.dichvu-foot{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:18px;
    margin-top:28px;
    padding:16px 18px;
    background:#fff;
    border:1px solid #ededed;
    border-radius:8px;
    box-shadow:0 10px 28px rgb(0 0 0 / 6%);
}
.dichvu-points{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
}
.dichvu-points span{
    display:inline-flex;
    align-items:center;
    gap:7px;
    color:#1f2933;
    font-weight:700;
    font-size:.92rem;
}
.dichvu-points i{color:var(--main);}
.dichvu-all{
    flex:0 0 auto;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:11px 16px;
    background:var(--main);
    color:#fff;
    border-radius:6px;
    font-weight:700;
    text-transform:uppercase;
}
.dichvu-all:hover{
    background:var(--hover);
    color:#111;
}
@media (max-width:991.98px){
    .dichvu{padding:54px 0 46px;}
    .dichvu-head{grid-template-columns:1fr;gap:14px;}
    .dichvu-head h2{font-size:1.65rem;}
    .dichvu-head p{margin-left:0;}
    .dichvu-foot{align-items:flex-start;flex-direction:column;}
}
@media (max-width:575.98px){
    .dichvu{padding:42px 0 34px;}
    .dichvu-head h2{font-size:1.38rem;}
    .dichvu-head p{font-size:.95rem;line-height:1.7;}
    .dichvu-info h3,.dichvu-info p{min-height:auto;}
    .dichvu-all{width:100%;}
}

/* home_doitac */
.dt-carousel .slick-slide > div{padding: 0 0.75rem;}
.dt-carousel .slick-arrow{position: absolute; top: calc(-32px - 2rem); right: 0; width: 30px; height: 30px; background-color: var(--main); border-radius: 50%;}
.dt-carousel .slick-arrow i{font-size: 14px; line-height: 30px; color: var(--wite);}
.dt-carousel .slick-arrow:hover{background-color: var(--hover);}
.dt-carousel .slick-prev{right: 35px}
.dt-item{position: relative; height: 100px; border: 1px solid var(--bord);}
.dt-item+.dt-item{margin-top: 1.5rem;}
.dt-item img{position: absolute; top: 0; right: 0; bottom: 0; left: 0; max-width: calc(100% - 1.5rem); max-height: calc(100% - 1.5rem); margin: auto;}
/* home_gioithieu */
.about{
    position: relative;
    padding: 80px 0 90px;
    background: #f3f3f3;
    overflow: hidden;
}
.about:before{
    content: "";
    position: absolute;
    inset: 0;
    background: url('/theme/images/bg-world-1.jpg') center center/cover no-repeat;
    opacity: .09;
    pointer-events: none;
}
.about .container{
    position: relative;
    z-index: 2;
}

.about-head{
    max-width: 1180px;
    margin: 0 auto 38px;
}

.about-title{
    position: relative;
    margin: 0 0 26px;
    text-align: center;
    color: var(--main);
    font-size: 2.1rem;
    font-weight: 400;
    line-height: 1.2;
    text-transform: uppercase;
    letter-spacing: .4px;
}
.about-title span{
    position: relative;
    display: inline-block;
    padding: 0 78px;
}
.about-title span:before,
.about-title span:after{
    content: "";
    position: absolute;
    top: 50%;
    width: 42px;
    height: 42px;
    margin-top: -21px;
    border-top: 1px solid var(--main);
}
.about-title span:before{
    left: 12px;
    border-left: 1px solid var(--main);
    transform: skewX(-42deg);
}
.about-title span:after{
    right: 12px;
    border-right: 1px solid var(--main);
    transform: skewX(42deg);
}
.about-title:before,
.about-title:after{
    content: "";
    position: absolute;
    top: 50%;
    width: calc(50% - 310px);
    height: 1px;
    background: var(--main);
}
.about-title:before{
    left: 0;
}
.about-title:after{
    right: 0;
}
.about-title i,
.about-title b{
    position: absolute;
    top: 50%;
    width: 12px;
    height: 12px;
    margin-top: -6px;
    background: var(--main);
    transform: rotate(45deg);
}
.about-title i{
    left: 0;
}
.about-title b{
    right: 0;
}

.about-intro{
    max-width: 900px;
    margin: 0 auto;
    color: #1f1f1f;
    font-size: 1.02rem;
    line-height: 1.9;
}

.about-body{
    display: grid;
    grid-template-columns: minmax(0, 1.02fr) minmax(0, .98fr);
    gap: 34px;
    align-items: start;
}

.about-left img{
    display: block;
    width: 100%;
    height: auto;
}

.about-right{
    padding-top: 4px;
}

.about-block{
    display: grid;
    grid-template-columns: 56px 1fr;
    gap: 16px;
    margin-bottom: 5px;
}
.about-icon{
    color: var(--main);
    font-size: 3rem;
    line-height: 1;
}
.about-content h3{
    margin: 0 0 10px;
    color: var(--main);
    font-size: 1.8rem;
    font-weight: 400;
    line-height: 1.2;
}
.about-content p{
    margin: 0 0 14px;
    color: #1f1f1f;
    font-size: 1.02rem;
    line-height: 1.8;
}
.about-content ul{
    margin: 0;
    padding-left: 18px;
}
.about-content li{
    margin-bottom: 12px;
    color: #1f1f1f;
    font-size: 1.02rem;
    line-height: 1.8;
}

@media (max-width: 1199.98px){
    .about-title{
        font-size: 1.8rem;
    }
    .about-title:before,
    .about-title:after{
        width: calc(50% - 260px);
    }
}

@media (max-width: 991.98px){
    .about{
        padding: 56px 0 64px;
    }
    .about-head{
        margin-bottom: 28px;
    }
    .about-title{
        font-size: 1.45rem;
        margin-bottom: 18px;
    }
    .about-title:before,
    .about-title:after,
    .about-title i,
    .about-title b,
    .about-title span:before,
    .about-title span:after{
        display: none;
    }
    .about-title span{
        padding: 0;
    }
    .about-intro{
        text-align: justify;
    }
    .about-body{
        grid-template-columns: 1fr;
        gap: 28px;
    }
}

@media (max-width: 575.98px){
    .about{
        padding: 40px 0 46px;
    }
    .about-title{
        font-size: 1.18rem;
        line-height: 1.35;
    }
    .about-intro{
        font-size: .95rem;
        line-height: 1.75;
    }
    .about-block{
        grid-template-columns: 42px 1fr;
        gap: 12px;
        margin-bottom: 24px;
    }
    .about-icon{
        font-size: 2.2rem;
    }
    .about-content h3{
        font-size: 1.35rem;
    }
    .about-content p,
    .about-content li{
        font-size: .95rem;
        line-height: 1.7;
    }
}
.tp-about{position:relative;overflow:hidden;padding:64px 0 72px;background:linear-gradient(180deg,#fff 0%,#f7f8fa 100%);font-family:inherit;}
.tp-about:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 12% 10%,rgba(218,37,28,.08),transparent 30%),radial-gradient(circle at 88% 12%,rgba(254,203,25,.18),transparent 25%),linear-gradient(135deg,transparent 44%,rgba(0,174,239,.05));pointer-events:none;}
.tp-about .container{position:relative;z-index:1;}
.tp-about-head{max-width:760px;margin:0 auto 34px;text-align:center;}
.tp-eyebrow{display:inline-flex;align-items:center;gap:10px;color:var(--main);font-size:.95rem;font-weight:700;text-transform:uppercase;}
.tp-eyebrow:before{content:"";width:34px;height:3px;background:var(--main);}
.tp-eyebrow:after{content:"";width:34px;height:3px;background:var(--main);}
.tp-about-title{margin:10px 0 0;color:#1f2933;font-size:2.05rem;font-weight:800;line-height:1.22;}
.tp-about-body{display:grid;grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr);gap:34px;align-items:center;}
.tp-media{position:relative;}
.tp-media-main{position:relative;overflow:hidden;border-radius:8px;background:#fff;box-shadow:0 16px 38px rgb(0 0 0 / 11%);}
.tp-media-main img{width:100%;aspect-ratio:16/11;object-fit:cover;transform:scale(1.01);transition:transform .5s ease;}
.tp-media-main:hover img{transform:scale(1.06);}
.tp-media-logo{position:absolute;left:18px;bottom:18px;width:112px;padding:8px;background:rgba(255,255,255,.94);border-radius:6px;box-shadow:0 10px 26px rgb(0 0 0 / 18%);}
.tp-media-logo img{width:100%;height:auto;object-fit:contain;}
.tp-media-strip{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:12px;}
.tp-media-strip img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:6px;box-shadow:0 10px 24px rgb(0 0 0 / 10%);transition:transform .35s ease,box-shadow .35s ease;}
.tp-media-strip img:hover{transform:translateY(-4px);box-shadow:0 16px 34px rgb(0 0 0 / 14%);}
.tp-stat-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:14px;}
.tp-stat{padding:14px 10px;background:#fff;border:1px solid #ededed;border-radius:6px;text-align:center;box-shadow:0 8px 22px rgb(0 0 0 / 6%);transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;}
.tp-stat:hover{transform:translateY(-3px);border-color:rgba(218,37,28,.22);box-shadow:0 14px 30px rgb(218 37 28 / 10%);}
.tp-stat i{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;margin:0 auto;color:var(--main);background:#fff4f3;border:1px solid rgba(218,37,28,.12);border-radius:50%;font-size:1.35rem;}
.tp-stat span{display:block;margin-top:6px;color:#555;font-size:.86rem;font-weight:600;}
.tp-content{display:grid;gap:16px;}
.tp-summary{position:relative;padding:22px 24px;background:#fff;color:#333;border:1px solid #ededed;border-top:4px solid var(--main);border-radius:8px;box-shadow:0 12px 30px rgb(0 0 0 / 7%);overflow:hidden;}
.tp-summary:before{content:"";position:absolute;right:-54px;top:-70px;width:160px;height:160px;border-radius:50%;background:rgba(254,203,25,.18);}
.tp-summary:after{content:"";position:absolute;left:0;bottom:0;width:100%;height:3px;background:linear-gradient(90deg,var(--main),var(--hover),rgba(0,174,239,.45));}
.tp-summary p{position:relative;margin:0;font-size:1.02rem;line-height:1.75;}
.tp-summary strong{color:var(--main);}
.tp-admin-content{padding:22px;background:#fff;border:1px solid #ededed;border-left:4px solid var(--main);border-radius:8px;box-shadow:0 10px 30px rgb(0 0 0 / 7%);color:#333;line-height:1.75;}
.tp-admin-content > *:last-child{margin-bottom:0;}
.tp-admin-content h1,.tp-admin-content h2,.tp-admin-content h3,.tp-admin-content h4{margin:0 0 12px;color:var(--main);font-weight:700;line-height:1.3;}
.tp-admin-content p{margin:0 0 12px;}
.tp-admin-content ul,.tp-admin-content ol{margin:0 0 12px;padding-left:20px;}
.tp-admin-content li{margin-bottom:7px;}
.tp-admin-content a{color:var(--main);font-weight:700;}
.tp-admin-content img{max-width:100%;height:auto;border-radius:6px;}
.tp-feature{display:grid;grid-template-columns:58px minmax(0,1fr);gap:18px;padding:22px;background:#fff;border:1px solid #ededed;border-left:4px solid var(--main);border-radius:8px;box-shadow:0 10px 30px rgb(0 0 0 / 7%);transition:transform .28s ease,box-shadow .28s ease,border-color .28s ease;}
.tp-feature:hover{transform:translateY(-4px);box-shadow:0 18px 42px rgb(218 37 28 / 12%);border-left-color:var(--hover);}
.tp-feature-icon{display:flex;align-items:center;justify-content:center;width:58px;height:58px;background:#fff4f3;color:var(--main);border:1px solid rgba(218,37,28,.10);border-radius:8px;font-size:1.85rem;}
.tp-feature h3{margin:0 0 10px;color:var(--main);font-size:1.45rem;font-weight:700;}
.tp-feature p{margin:0;color:#333;line-height:1.75;}
.tp-feature ul{display:grid;gap:9px;margin:0;padding:0;list-style:none;}
.tp-feature li{position:relative;padding-left:22px;color:#333;line-height:1.65;}
.tp-feature li:before{content:"";position:absolute;left:0;top:.68em;width:8px;height:8px;background:var(--hover);border-radius:50%;}
.tp-chip-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px;}
.tp-chip-list span{display:inline-flex;align-items:center;padding:8px 11px;background:#f8eeee;color:var(--main);border:1px solid rgba(218,37,28,.16);border-radius:6px;font-size:.92rem;font-weight:700;}
.tp-promise{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;padding:12px;background:#fff;border:1px solid #ededed;border-radius:8px;box-shadow:0 10px 26px rgb(0 0 0 / 6%);}
.tp-promise span{display:flex;align-items:center;justify-content:center;min-height:44px;padding:8px 10px;background:#fff8df;color:#7a4b00;border-radius:6px;font-size:.9rem;font-weight:700;text-align:center;}
.tp-actions{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,1.2fr) minmax(130px,.8fr);gap:10px;padding:12px;background:#fff;border:1px solid rgba(218,37,28,.12);border-radius:8px;box-shadow:0 8px 20px rgb(15 23 42 / 6%);}
.tp-actions a{display:flex;align-items:center;justify-content:center;gap:8px;min-width:0;min-height:70px;border-radius:6px;font-weight:700;transition:transform .25s ease,background .25s ease,color .25s ease,box-shadow .25s ease;}
.tp-action-more{padding:12px 14px;background:#f4f5f7;color:#333;text-transform:uppercase;border:1px solid #e7e9ee;}
.tp-action-profile{position:relative;padding:10px 12px;background:#fffaf0;color:#7a170f;overflow:hidden;border:1px solid rgba(218,37,28,.14);box-shadow:none;}
.tp-action-certificate{background:#fff;color:#333;border-color:#e7e9ee;box-shadow:none;}
.tp-action-profile:before{display:none;}
.tp-action-certificate:before{display:none;}
.tp-action-profile-icon{display:inline-flex;align-items:center;justify-content:center;flex:0 0 32px;width:32px;height:32px;background:var(--main);color:#fff;border-radius:6px;font-size:1rem;}
.tp-action-profile span:not(.tp-action-profile-icon){position:relative;display:grid;gap:2px;min-width:0;text-align:left;}
.tp-action-profile strong{font-size:.9rem;text-transform:uppercase;line-height:1.15;}
.tp-action-certificate strong{white-space:nowrap;font-size:.9rem;}
.tp-action-profile small{color:#8a5a00;font-size:.74rem;font-weight:700;line-height:1.25;text-transform:none;}
.tp-action-profile > i{position:relative;margin-left:auto;color:var(--main);}
.tp-action-certificate > i{margin-left:auto;color:#777;font-size:.88rem;}
.tp-actions a:hover{transform:translateY(-1px);background:#fff;color:var(--main);box-shadow:0 8px 18px rgb(0 0 0 / 8%);}
.tp-actions a:hover .tp-action-profile-icon{background:var(--main);color:#fff;}
.tp-action-more:hover{background:#f0f1f4!important;color:var(--main)!important;}
@media (max-width:991.98px){
    .tp-about{padding:46px 0 54px;}
    .tp-about-body{grid-template-columns:1fr;}
    .tp-about-title{font-size:1.85rem;}
    .tp-promise{grid-template-columns:1fr;}
}
@media (max-width:575.98px){
    .tp-about{padding:36px 0 44px;}
    .tp-about-title{font-size:1.45rem;}
    .tp-summary p,.tp-feature p,.tp-feature li{font-size:.95rem;line-height:1.7;}
    .tp-media-logo{left:12px;bottom:12px;width:84px;}
    .tp-stat-row{grid-template-columns:1fr;}
    .tp-feature{grid-template-columns:1fr;padding:18px;}
    .tp-feature-icon{width:48px;height:48px;font-size:1.45rem;}
    .tp-actions{grid-template-columns:1fr;}
    .tp-actions a{width:100%;}
}

/* home_sanpham */
.sup-heading{
    border-bottom:2px solid #4a9b55;
    margin-bottom:18px;
}

.sup-heading-left{
    display:inline-block;
}

.sup-heading-left span{
    display:inline-block;
    background:#5cab55;
    color:#fff;
    font-size:14px;
    font-weight:700;
    padding:10px 20px 10px 14px;
    text-transform:uppercase;
    line-height:1;
    position:relative;
    white-space:nowrap;
    clip-path:polygon(0 0,88% 0,100% 50%,88% 100%,0 100%);
}

.sup-heading-left span:after{
    content:"";
    position:absolute;
    right:-8px;
    top:0;
    width:6px;
    height:100%;
    background:#2b2b2b;
    transform:skewX(-20deg);
}

.sup-heading-right a{
    color:#555;
    font-size:14px;
    font-weight:500;
    transition:all .2s ease;
}

.sup-heading-right a:hover{
    color:#d1002c;
}

.sup-product-card{
    background:#fff;
    border:1px solid #e2e2e2;
    border-radius:4px;
    overflow:hidden;
    box-shadow:0 2px 8px rgba(0,0,0,.05);
    transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
}

.sup-product-card:hover{
    transform:translateY(-4px);
    box-shadow:0 8px 22px rgba(0,0,0,.10);
    border-color:#d7d7d7;
}

.sup-product-img{
    position:relative;
    background:#fff;
    border-bottom:1px solid #ededed;
    overflow:hidden;
    aspect-ratio:4/3;
}

.sup-product-img a{
    display:flex;
    align-items:center;
    justify-content:center;
    width:100%;
    height:100%;
    text-decoration:none;
    padding:10px;
}

.sup-product-img img{
    max-width:100%;
    max-height:100%;
    width:auto;
    height:auto;
    object-fit:contain;
    transition:transform .3s ease;
}

.sup-product-card:hover .sup-product-img img{
    transform:scale(1.04);
}

.sup-sale-badge{
    position:absolute;
    top:10px;
    left:0;
    z-index:2;
    background:#f3a320;
    color:#fff;
    font-size:12px;
    font-weight:700;
    line-height:1;
    padding:7px 10px;
    border-radius:0 0 10px 0;
    box-shadow:0 2px 6px rgba(0,0,0,.12);
}

.sup-product-info{
    padding:14px 12px 16px;
    text-align:center;
}

.sup-product-name{
    margin:0 0 8px;
    font-size:15px;
    font-weight:500;
    line-height:1.45;
    min-height:44px;
}

.sup-product-name a{
    color:#333;
    text-decoration:none;
    transition:color .2s ease;
    display:-webkit-box;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;
    overflow:hidden;
}

.sup-product-name a:hover{
    color:#d1002c;
}

.sup-product-price{
    line-height:1.45;
}

.sup-product-price .old-price{
    display:inline-block;
    color:#9a9a9a;
    text-decoration:line-through;
    font-size:14px;
    margin-right:6px;
}

.sup-product-price .new-price{
    color:#d1002c;
    font-size:15px;
    font-weight:700;
}

.sup-product-price .new-price strong{
    font-weight:700;
}

@media (max-width:1199.98px){
    .sup-product-name{
        font-size:14px;
        min-height:42px;
    }

    .sup-product-price .old-price{
        font-size:13px;
    }

    .sup-product-price .new-price{
        font-size:14px;
    }
}

@media (max-width:991.98px){
    .sup-heading-left span{
        font-size:13px;
        padding:10px 18px 10px 12px;
    }

    .sup-heading-right a{
        font-size:13px;
    }

    .sup-product-info{
        padding:12px 10px 14px;
    }

    .sup-product-name{
        font-size:14px;
        min-height:40px;
    }

    .sup-product-price .new-price{
        font-size:14px;
    }
}

@media (max-width:767.98px){
    .sup-heading-left span{
        font-size:12px;
        padding:9px 16px 9px 10px;
    }

    .sup-heading-right a{
        font-size:12px;
    }

    .sup-product-info{
        padding:10px 8px 12px;
    }

    .sup-product-name{
        font-size:13px;
        line-height:1.4;
        min-height:38px;
        margin-bottom:6px;
    }

    .sup-product-price .old-price{
        display:block;
        margin:0 0 2px;
        font-size:12px;
    }

    .sup-product-price .new-price{
        font-size:14px;
    }

    .sup-sale-badge{
        font-size:11px;
        padding:6px 8px;
    }
}

@media (max-width:575.98px){
    .sup-product-card{
        border-radius:3px;
        box-shadow:0 1px 6px rgba(0,0,0,.05);
    }

    .sup-product-card:hover{
        transform:translateY(-2px);
        box-shadow:0 5px 16px rgba(0,0,0,.08);
    }

    .sup-product-name{
        font-size:13px;
        min-height:36px;
    }

    .sup-product-price .new-price{
        font-size:14px;
    }
}
/* home_tintuc */
    .news-block {
      background: #fff;
    }

    .block-header {
      display: flex;
      align-items: center;
      justify-content: space-between;
      border-bottom: 2px solid var(--main);
      margin-bottom: 18px;
    }
    .block-title {
      position: relative;
      display: inline-block;
      height: 38px;
      line-height: 38px;
      padding: 0 56px 0 12px;
      background: var(--main);
      color: var(--white);    
      font-size: 15px;
      font-weight: 400;
      letter-spacing: 0.2px;
      text-transform: uppercase;
      white-space: nowrap;
      clip-path: polygon(0 0, calc(100% - 18px) 0, 100% 100%, 0 100%);
    }
    
    .block-title::before {
      content: "";
      position: absolute;
      top: 0;
      right: 16px;
      width: 12px;
      height: 100%;
      background: var(--hover);
      transform: skewX(28deg);
    }
    
    .block-title::after {
      content: "";
      position: absolute;
      top: 0;
      right: 2px;
      width: 12px;
      height: 100%;
      background: var(--main);
      transform: skewX(28deg);
    }   

    .view-all {
      color: #555;
      text-decoration: none;
      font-size: 14px;
    }

    .view-all:hover {
      color: var(--hover);
    }

    .view-all span {
      font-size: 18px;
      vertical-align: middle;
      margin-left: 4px;
    }

    .post-item {
      display: flex;
      gap: 18px;
      margin-bottom: 14px;
    }

    .post-thumb {
      min-width: 190px;
      height: 165px;
      overflow: hidden;
      background: #ddd;
    }

    .post-thumb img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
    }

    .post-content {
      flex: 1;
      padding-right: 10px;
    }

    .post-title {
      font-size: 17px;
      font-weight: 500;
      color: #222;
      text-decoration: none;
      display: block;
      margin-bottom: 8px;
      line-height: 1.35;
    }

    .post-title:hover {
      color: var(--hover);
    }

    .post-desc {
      color: #333;
      font-size: 15px;
      line-height: 1.65;
      margin-bottom: 12px;

      display: -webkit-box;
      -webkit-line-clamp: 3;
      -webkit-box-orient: vertical;
      overflow: hidden;
    }

    .read-more {
      display: inline-block;
      color: var(--main);
      font-weight: 700;
      text-transform: uppercase;
      text-decoration: none;
      font-size: 14px;
      position: relative;
      padding-bottom: 6px;
    }

    .read-more::after {
      content: "";
      position: absolute;
      left: 0;
      bottom: 0;
      width: 54px;
      height: 2px;
      background: #cfd8cf;
    }

    .read-more:hover {
      color: var(--hover);
    }

    @media (max-width: 991.98px) {
      .post-thumb {
        width: 160px;
        min-width: 160px;
        height: 135px;
      }

      .post-title {
        font-size: 16px;
      }

      .post-desc {
        font-size: 14px;
      }
    }

    @media (max-width: 767.98px){
  .post-item{
    display:flex;
    gap:10px;
    margin-bottom:8px;
  }

  .post-thumb{
    width:145px;
    min-width:145px;
    height:132px;
  }

  .post-thumb img{
    width:100%;
    height:100%;
    object-fit:cover;
  }

  .post-content{
    flex:1;
    min-width:0;
  }

  .post-title{
    display:-webkit-box;
    -webkit-line-clamp:1;
    -webkit-box-orient:vertical;
    overflow:hidden;
    font-size:13px;
    line-height:1.4;
    margin-bottom:4px;
  }

  .post-desc{
    display:-webkit-box;
    -webkit-line-clamp:4;
    -webkit-box-orient:vertical;
    overflow:hidden;
    font-size:12px;
    line-height:1.6;
    margin-bottom:6px;
  }

  .read-more{
    font-size:12px;
    font-weight:700;
    text-transform:uppercase;
    color:#6eaf66;
    text-decoration:none;
    position:relative;
    padding-bottom:6px;
  }

  .read-more::after{
    content:"";
    position:absolute;
    left:0;
    bottom:0;
    width:48px;
    height:2px;
    background:#d8e3d3;
  }

  .section-title{
    font-size:14px;
    padding:10px 18px 10px 12px;
  }

  .view-all{
    font-size:12px;
  }
}
/* kiem_dinh */
.certificate-page{padding:56px 0 70px;background:linear-gradient(180deg,#fff 0%,#f8fafc 100%);}
.certificate-head{max-width:760px;margin:0 auto 28px;text-align:center;}
.certificate-head span{display:inline-flex;align-items:center;gap:10px;color:var(--main);font-weight:800;text-transform:uppercase;}
.certificate-head span:before,.certificate-head span:after{content:"";width:34px;height:3px;background:var(--main);}
.certificate-head h1{margin:10px 0 12px;color:#1f2933;font-size:2rem;font-weight:800;line-height:1.25;}
.certificate-head p{margin:0;color:#5b6573;font-size:1rem;line-height:1.7;}
.certificate-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;}
.certificate-card{display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:start;padding:20px;border:1px solid #edf0f4;border-radius:8px;background:#fff;box-shadow:0 12px 30px rgb(15 23 42 / 8%);}
.certificate-icon{display:flex;align-items:center;justify-content:center;width:58px;height:58px;border-radius:8px;background:rgb(218 37 28 / 10%);color:var(--main);font-size:1.75rem;}
.certificate-body{min-width:0;}
.certificate-meta{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px;}
.certificate-meta span{display:inline-flex;align-items:center;min-height:26px;padding:4px 10px;border-radius:999px;background:#fff8df;color:#6b4f00;font-size:.78rem;font-weight:800;line-height:1;}
.certificate-body h2{margin:0 0 8px;color:#172033;font-size:1.18rem;font-weight:800;line-height:1.35;}
.certificate-body p{margin:0 0 12px;color:#606a78;line-height:1.65;}
.certificate-info{display:flex;flex-wrap:wrap;gap:10px 14px;color:#3d4654;font-size:.9rem;font-weight:700;}
.certificate-info span{display:inline-flex;align-items:center;gap:7px;}
.certificate-info i{color:var(--main);}
.certificate-actions{grid-column:1 / -1;display:flex;flex-wrap:wrap;gap:10px;padding-top:14px;border-top:1px solid #edf0f4;}
.certificate-actions a{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:42px;padding:10px 14px;border-radius:6px;font-weight:800;line-height:1;transition:transform .25s ease,background .25s ease,color .25s ease,border-color .25s ease;}
.certificate-view{background:var(--main);color:#fff;}
.certificate-download{border:1px solid rgb(218 37 28 / 22%);background:#fff;color:var(--main);}
.certificate-actions a:hover{transform:translateY(-2px);background:var(--hover);border-color:var(--hover);color:#111;}
.certificate-empty-file{display:inline-flex;align-items:center;gap:8px;min-height:42px;padding:10px 14px;border-radius:6px;background:#f3f5f8;color:#647083;font-weight:800;}
.certificate-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;min-height:180px;padding:30px;border:1px dashed #d8dee8;border-radius:8px;background:#fff;color:#657082;text-align:center;}
.certificate-empty i{color:var(--main);font-size:2rem;}
.certificate-empty p{margin:0;font-weight:700;}
@media (max-width:991.98px){
    .certificate-grid{grid-template-columns:1fr;}
}
@media (max-width:575.98px){
    .certificate-page{padding:38px 0 48px;}
    .certificate-head h1{font-size:1.45rem;}
    .certificate-card{grid-template-columns:1fr;padding:16px;}
    .certificate-icon{width:52px;height:52px;}
    .certificate-actions a{width:100%;}
}

/* news */
.news-list-section{background:#f3f3f3;}
.news-item{width:100%;}
.news-item .tt-item{display:flex;flex-direction:row;align-items:stretch;width:100%;background:#fff;overflow:hidden;}
.news-item .i-hov{width:380px;min-width:380px;max-width:380px;height:250px;position:relative;overflow:hidden;flex-shrink:0;}
.news-item .i-hov a{display:block;width:100%;height:100%;}
.news-item .i-hov img{display:block;object-fit:cover;}
.news-item .entry-time{position:absolute;top:14px;left:14px;width:56px;height:56px;background:#fff;color:var(--main);font-weight:700;display:flex;flex-direction:column;align-items:center;justify-content:center;line-height:1.1;z-index:2;box-shadow:0 2px 8px rgba(0,0,0,.08);}
.news-item .entry-time span{display:block;font-size:13px;margin-top:2px;}
.news-item .tt-info{flex:1;padding:20px 24px;}
.news-item .tt-info h2{margin:0 0 10px;font-size:22px;line-height:1.35;}
.news-item .tt-info h2 a{color:#111;text-decoration:none;}
.news-item .tt-info h2 a:hover{color:var(--hover);}
.news-item .tt-info p{margin:0 0 14px;font-size:16px;line-height:1.7;color:#333;}
.news-item .tt-more a{color:var(--main);text-decoration:none;font-weight:600;}

@media (max-width:991.98px){
    .news-item .tt-item{flex-direction:column;}
    .news-item .i-hov{width:100%;min-width:100%;max-width:100%;height:auto;}
    .news-item .i-hov img{height:auto;}
    .news-item .tt-info{padding:16px;}
    .news-item .tt-info h2{font-size:22px;}
    .news-item .tt-info p{font-size:15px;}
}
/* product_detail */
 .card-img-top {aspect-ratio: 16 / 10;object-fit: cover;}
 .main-other h3{text-transform: uppercase;}
.product-head{background-color: var(--wite); border: 1px solid rgb(0 0 0 / 6%); box-shadow: 0 6px 18px rgb(0 0 0 / 4%);}
.product-title{background: url(/theme/images/detail.png) no-repeat bottom left / cover;}
.product-title h1{font-size: inherit; line-height: 1.5;}
.product-info h1{border-bottom: 1px solid var(--bord);}
.product-info .main-button a{background-color: var(--hover); border-color: var(--hover); color: var(--wite);}
.product-info .main-button a:hover{background-color: var(--main); border-color: var(--main); color: var(--hover);}
.product-info > a:hover{color: var(--hover);}
.product-tabs{list-style: none;}
.product-tabs li{flex: 0 0 auto; line-height: 50px;}
.product-tabs li a{display: block; padding: 0 1.5rem; text-transform: uppercase; color: var(--text);}
.product-tabs li a.active{background-color: var(--wite); color: var(--main);}
.product-content{background-color: var(--wite); border: 1px solid rgb(0 0 0 / 6%); box-shadow: 0 6px 18px rgb(0 0 0 / 4%);}
.product-content .main-other{border-width: 1px; font-family: Lexend, 'Helvetica Neue', Arial, sans-serif; font-weight: 400; color: var(--main);}
.product-content .main-other *:before{height: 1px; background-color: var(--hover);}
.spD-big{background-color: var(--wite); box-shadow: 0 6px 12px -8px rgb(0 0 0 / 8%);}
.spD-big .slick-slide > div{position: relative; height: 0; padding-top: 100%; cursor: pointer;}
.spD-big .slick-slide > div img{object-fit: contain;}
.spD-nav .slick-slide{margin: 0 0.25rem; padding: 0.25rem; background-color: var(--wite);}
.spD-nav .slick-slide > div{position: relative; height: 0; padding-top: calc(100%/3*2); cursor: pointer;}
.spD-nav .slick-slide > div img{object-fit: contain;}
.spD-nav .slick-arrow{position: absolute; bottom: 0; width: 40px; height: calc(100% - 1rem); margin: auto; opacity: 50%;}
.spD-nav .slick-arrow:hover{opacity: 1;}
.spD-nav .slick-arrow i{display: flex; height: 100%; align-items: center; justify-content: center; color: var(--wite);}
.spD-nav .slick-prev{left: 0; background: linear-gradient(90deg, var(--main) 25%, transparent 100%);}
.spD-nav .slick-next{right: 0; background: linear-gradient(270deg, var(--main) 25%, transparent 100%)}
@media all and (max-width: 992px){

}
@media all and (max-width: 576px){
    .product-tabs li a{padding: 0 1rem; text-transform: none;}
}
/* profile */
.profile-page{padding:56px 0 68px;background:linear-gradient(180deg,#fff 0%,#f7f8fa 100%);}
.profile-head{text-align:center;margin-bottom:22px;}
.profile-head span{display:inline-flex;align-items:center;gap:10px;color:var(--main);font-weight:700;text-transform:uppercase;}
.profile-head span:before,.profile-head span:after{content:"";width:34px;height:3px;background:var(--main);}
.profile-head h1{margin:8px 0 0;color:#1f2933;font-size:2rem;font-weight:800;line-height:1.25;}
.profile-head p{max-width:760px;margin:10px auto 0;color:#5b6573;font-size:1rem;line-height:1.7;}
.profile-toolbar{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:10px;margin-bottom:18px;}
.profile-btn,.profile-download{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:42px;padding:10px 14px;border:0;border-radius:6px;background:var(--main);color:#fff;font-weight:700;line-height:1;transition:transform .25s ease,background .25s ease,color .25s ease;}
.profile-btn{width:46px;padding:0;cursor:pointer;}
.profile-btn:disabled{opacity:.45;cursor:not-allowed;}
.profile-btn:not(:disabled):hover,.profile-download:hover{transform:translateY(-2px);background:var(--hover);color:#111;}
.profile-counter{min-height:42px;display:inline-flex;align-items:center;justify-content:center;padding:9px 16px;border:1px solid #ededed;border-radius:6px;background:#fff;color:#333;font-weight:600;box-shadow:0 8px 22px rgb(0 0 0 / 6%);}
.profile-book-wrap{position:relative;display:flex;align-items:center;justify-content:center;width:100%;min-height:660px;padding:18px;background:#7f1d1d;border-radius:8px;box-shadow:0 18px 44px rgb(0 0 0 / 18%);overflow:hidden;}
.profile-book{margin:auto;}
.profile-paper{background:#fff;overflow:hidden;}
.profile-paper-inner{position:relative;display:flex;align-items:center;justify-content:center;width:100%;height:100%;background:#fff;}
.profile-paper.is-loading .profile-paper-inner:before{content:"Đang tải trang...";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#777;font-size:14px;font-weight:700;background:#fff;}
.profile-paper img{display:block;width:100%;height:100%;object-fit:contain;background:#fff;user-select:none;-webkit-user-drag:none;}
.profile-paper.is-loading img{visibility:hidden;}
.profile-loading{position:absolute;inset:18px;display:flex;align-items:center;justify-content:center;background:#fff;color:#555;font-weight:700;z-index:10;}
.profile-book-wrap.is-ready .profile-loading{display:none;}
.profile-fallback{margin:14px 0 0;text-align:center;color:#555;}
.profile-fallback a{color:var(--main);font-weight:700;}
.profile-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;min-height:180px;padding:30px;border:1px dashed #d8dee8;border-radius:8px;background:#fff;color:#657082;text-align:center;}
.profile-empty i{color:var(--main);font-size:2rem;}
.profile-empty p{margin:0;font-weight:700;}
@media (max-width:767.98px){
    .profile-page{padding:38px 0 46px;}
    .profile-page .container{width:calc(100% - 24px);max-width:none;}
    .profile-head h1{font-size:1.45rem;}
    .profile-book-wrap{min-height:520px;padding:12px;}
    .profile-download{width:100%;}
}

/* service */
.sv-card{
    height: 100%;
    display: flex;
    flex-direction: column;
}

.sv-item{
    position: relative;
    overflow: hidden;
}

.sv-item img{
    position: relative;
    border-radius: 15px;
    transform: scale(95%);
    z-index: 2;
    transition: all 0.25s ease 0s;
}

.sv-item img:hover{
    transform: scale(1);
    border-radius: 15px;
}

.sv-item:before,
.sv-item:after{
    content: '';
    position: absolute;
    width: 50%;
    height: 50%;
    z-index: 1;
}

.sv-item:before{
    top: 0;
    right: 0;
    border-top: 1px solid var(--main);
    border-right: 1px solid var(--main);
    border-radius: 0 15px 0 0;
}

.sv-item:after{
    bottom: 0;
    left: 0;
    border-bottom: 1px solid var(--main);
    border-left: 1px solid var(--main);
    border-radius: 0 0 0 15px;
}

.sv-title{
    margin: 15px 20px 0;
    padding: 12px 15px;
    min-height: 78px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    background-color: rgb(255 255 255 / 75%);
    border-radius: 5px;
}

.sv-title a{
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    color: #222;
    text-decoration: none;
    line-height: 1.4;
}
/* side */
aside{background-color: var(--wite); border: 1px solid rgb(0 0 0 / 6%); box-shadow: 0 6px 18px rgb(0 0 0 / 4%);}
.side-title{background-color: var(--main); border-bottom: 3px solid var(--hover); border-radius: 5px 5px 0 0; color: #fff;}
.side-dm ul{list-style: none;}
.side-dm ul li+li{border-top: 1px dashed var(--border);}
.side-dm ul li a:hover{padding-left: 0.5rem; color: var(--hover);}
.side-dm ul li.active a{color: var(--hover);}
.side-ht img{width: 40px;}
.side-ht a:last-child{border-top: 1px solid #d7d7d7;}
.side-ht a:last-child img{width: 21px; vertical-align: top;}
.side-bv h3{display: -webkit-box; width: calc(100% - 100px - 1rem); -webkit-line-clamp: 3; -webkit-box-orient: vertical; text-overflow: ellipsis; overflow: hidden;font-weight: normal;}
/* z_popup */
.popup{width: calc(100% - 1rem);  max-width: 576px; margin: 0 auto;}
.popup-title{padding: 0 15px; background-color: var(--main); border-radius: 20px 20px 0 0; line-height: 50px; color: #fff;}
.popup-form{background-color: #fff; border-radius: 0 0 20px 20px;}
.loading-indicator-overlay, .loading-indicator{z-index: 99993!important;}
.fancybox-close-small{width: 50px; height: 50px;}
.fancybox-close-small:after{top: 10px; right: 10px; color: #fff;}
